import { NextResponse } from "next/server"; import automation from "data/automation.json"; const get = (url) => { console.log("get", url); return fetch(url, { cache: "no-store" }) .then((resp) => resp && resp.text()) .then((result) => result); }; const update = ({ id, client, on, bri, ...rest }) => { let url = `http://${client}/win`; if (id) url += `&PL=${id}`; if (on) url += `&T=1`; else url += `&T=0`; if (bri) url += `&A=${bri}`; return get(url) .then((resp) => ({ ps: id, on: on, bri: bri })) .catch((err) => ({ error: err.message })); }; export async function GET(req, { params }) { let promises = []; let id = params?.id || null; try { if (!id) throw new Error("No id specified"); let clients = (automation?.[id] && Object.keys(automation?.[id])) || []; if (!clients) throw new Error("No clients fowr id", id); for (let client of clients) { promises.push(update({ id, client, ...automation?.[id]?.[client] })); } } catch (err) { return NextResponse.json({ error: err?.message }, { status: 500 }); } return Promise.allSettled(promises) .then((results) => { return NextResponse.json(results?.map((o) => o?.value)); }) .catch((err) => { return NextResponse.json({ error: err?.message }, { status: 500 }); }); }